## **CSE460 Lab3 assessment**

Name: Pratick Bhowmick

Id: 20101262 Section: 05

## Task1:

```
Code:
module lab3assessment(y,w,flag);
input [7:0]w;
input flag;
output reg [2:0]y;
always@(flag, w)
       if (flag == 1)
              y = 2; // Last digit of ID
       else
              begin
                      casex(w)
                             8'bxx1xxxxx: y = 5;
                             8bxx0xxxx1: y = 0;
                             8'bxx0xxx10: y = 1;
                             8bxx0xx100: y = 2;
                             8'bx10xx000: y = 6;
                             8'bx00x1000: y = 3;
                             8'b100x0000: y = 7;
                             8'b00010000: y = 4;
                      endcase
              end
```

endmodule

Circuit:







## Timing Diagram:



Task2:

```
Code:
module lab3assessment(q, d, load, clk);
input [4:0]d;
input load, clk;
output reg [4:0]q;
always@(posedge clk)
        if(load)
               q \le d;
        else
               begin
                        q[4] <= q[3];
                       q[3] <= q[2];
                        q[2] <= q[1];
                       q[1] <= q[0];
                        q[0] <= q[4];
               end
```

endmodule

Circuit:



## Timing diagram:

